# Compliance Task Group Call – Agenda

Weds, Mar10 2020 8am Pacific → Daylight ← Time

See slides 9,10 for discussions and action items

### Charter

### The Compliance Task Group will

- Develop compliance tests for RISC-V implementations, taking into account approved specifications for:
  - Architectural versions (e.g. RV32I, RV32E, RV64I, RV128I)
  - Standard Extensions (M,A,F,D,Q,L,C,B,J,T,P,V,N)
  - All spec'ed implementation options
    - (incl. MHSU modes, optional CSRs, optional CSR bits)
- Develop a method for selecting <u>and</u> configuring appropriate tests for a RISC-V implementation, taking into account:
  - Platform profile and Execution Environment (EE)
  - Implemented architecture, extensions, and options
- Develop a framework to apply the appropriate tests to an implementation and verify that it meets the standard
  - test result signature stored in memory will be compared to a golden model result signature

### Adminstrative Pointers

Chair – Allen Baum

allen.baum@esperantotech.com

- Co-chair TBD
- TG Email <u>tech-compliance@lists.riscv.org</u>
  - Notetakers: please send emails to allen.baum@esperantotech.com
- Meetings -Bi-monthly at 8am Pacific time on 2<sup>nd/</sup>4<sup>th</sup> Wednesdays
  - See <a href="https://lists.riscv.org/g/tech-compliance/calendar">https://lists.riscv.org/g/tech-compliance/calendar</a> entry for zoom link
- Documents, calendar, roster, etc. in <a href="https://lists.riscv.org/tech-compliance/">https://lists.riscv.org/tech-compliance/</a> see /documents, /calendars subdirectories
  - https://riscof.readthedocs.io/en/latest/ riscof
  - <a href="https://riscv-config.readthedocs.io/en/latest/">https://riscv-config.readthedocs.io/en/latest/</a> config: YAML and WARL spec
- Git repositories
  - https://github.com/riscv/riscv-compliance/
  - https://github.com/rsnikhil/Experimental RISCV Feature Model
  - https://github.com/rsnikhil/Forvis RISCV-ISA-Spec
  - <a href="https://gitlab.com/incoresemi/riscof">https://gitlab.com/incoresemi/riscof</a> (Shakti framework)

# Meeting Agenda

- Review of issues (and getting owners to fix them)
- Next steps (and their ordering):
  - More tests?
    - Better coverage of existing tests vs. new tests (primarily priv level)
  - Coverage metrics?
  - Transitioning to v.2?
  - Funding?
  - Other?

### Discussion

- 1. Poll, passed with little participation
  Comment new version of the test spec isn't crucial –
  getting more tests are.
- 2. Neel reviewed updated riscof framework (slide 9)
  - 1. improvements in setup and documentation
  - 2. New features: able to do custom test suite selection
  - 3. There is a docker image that has been created (somewhere)
  - 4. There are still too many OS dependencies (libraries)
- 3. Looked at other pull requests all now merged
- 4. Looked at issue list
  - 1. Decided that many required test configuration, not possible in V.1, so will relabel them (and possibly close)
  - 2. In general, more important to get more tests written than to get issues resolved.
  - 3. Others require major test reorganization and re-writing, may need to wait until v.2
  - 4. Close #38 as not a bug

### **Decisions & Action Items**

### **Decisions**

- 1. Riscof needs to remove OS dependencies before it can be declared v.2
  - 1. Installation is still difficult
- 2. Getting more tests is top priority
  - 1. Higher than fixing issues
  - 2. In general, more important to get more tests written than to get issues resolved.
  - 3. Others require major test reorganization and re-writing, may need to wait until v.2

### **Action Items**

Anybody:Rv64i tests need to be re-written!

Neel: eliminate or document OS dependencies (Debian vs. Ubuntu vs. Centos (vs. MacOS?)

Allen: upload coverage spec draft to lists.riscv.org/g/tech-compliance/files/Review Documents/ (done)

Allen: contact submitters of fixed issues to close

Allen: put coverage draft into <a href="https://lists.riscv.org/g/tech-compliance/files/Review Documents">https://lists.riscv.org/g/tech-compliance/files/Review Documents</a>

### Action Items from last meeting

Anybody:Rv64i tests need to be re-written! (still – wait for funding?)

Allen: Need funding for tests –started

Allen: contact Issue 84 submitter to reopen it (done)

Allen: Re-order issue list into categories: done

not a bug, should be closed

bug, unfixable in v.1, mark TBD?

bug - should be fixed

bug – has been fixed, should be closed

Allen: contact submitters of fixed issues to close (not done)

## Riscof update details

RISCOF version 1.13.1 has just been released which includes the following changes/additions:

RISCOF: <a href="https://gitlab.com/incoresemi/riscof">https://gitlab.com/incoresemi/riscof</a>

RISCOF-PLUGINS: <a href="https://gitlab.com/incoresemi/riscof-plugins">https://gitlab.com/incoresemi/riscof-plugins</a>

Updates docs: https://riscof.readthedocs.io/en/latest/

- Docs have been significantly updated with more details and a better quickstart
- PYTHONPATH no longer needs to be set for the plugins. All the information is picked up from the config.ini itself.
- RISCOF now checks that both signatures are not empty before comparing them
- RISCOF has now shifted to use all the new tests (with better coverage) from github
- RISCOF now allows people to run custom suites using the --suite. This mean for developers who want to write new tests or for those who do not wish to run the entire suite but only a sub-set.
- The plugins now have a makeutility available which can be used to quickly generate makefile. The spike\_parallel and riscvOVPsim plugins have been updated to use this utility. The user can also now choose what make command to use (e.g. pmake, make -j, etc). Default is make which should work on all distros
- · Print the help command when no argument are specified
- Print version on execution
- The --setup command now generates all collaterals (including a python plugin template) required to execute RISCOF
- All the hard-coded paths in the spike\_simple plugin have been removed and should now work as is on any system with changes only happening in config.ini

# Pull/Issue Status

| Issue#          | date                 | submitter           | title                                                          | status                   |                                        |
|-----------------|----------------------|---------------------|----------------------------------------------------------------|--------------------------|----------------------------------------|
| #04             | 3-Jul-18             | kasanovic           | Section 2.3 Target Environment                                 | ??                       | will be fixed in V.2                   |
| #30             | 21-Jan-19            | RolfyYu             | The golden results of rv32ui and rv64ui should be different    | bug                      | most rv64 tests need rewriting         |
| #08             | 17-Oct-18            | AnttiLukats         | RV32I/I-IO.S bad file name                                     |                          | change file name                       |
| #37             | 31-Jan-19            | astimonov           | rv32imc C.SWSP test5 writes a word outside the binary          | bug - needs fixing       | will be fixed in V.2                   |
| #40             | 4-Feb-19             | debs-sifive         | Usage of tohost/fromhost should be removed                     |                          | change makefile.include? Fixed in V.2? |
| #42             | 5-Feb-19             | as-sc               | Misaligned fetch bit must be excluded for RVC                  |                          | reset code chg if mdeleg is RO?        |
| #78             | 26-Jan-20            | bobbl               | RV_COMPLIANCE_HALT must contain SWSIG                          |                          | change macros as described             |
| #84             | 4-Feb-20             | towoe               | I-SW-01 corrupts .text region                                  |                          | change test                            |
| #95             | 03-Mar-20            | dsw                 | doc directory does not build                                   |                          | ?? title & document history mismatch   |
| #96             | 05-Mar-20            | dsw                 | how to run all RV64 tests, e.g./rv32ui/rv64ui, through spike?  |                          | Documentation fixup?                   |
| #90             | 11-Feb-20            | towoe               | Report target execution error                                  |                          | will be fixed in V.2                   |
| #03             | 3-Jul-18             | kasanovic           | 2.4 Processor configuration clarification                      |                          |                                        |
| <del>#09</del>  | <del>22-Oct-18</del> | <del>neelgala</del> | Setting SATP and PMP should be optional (closed)               |                          |                                        |
| #16             | 7-Nov-18             | neelgala            | I-MISALIGN_JMP-01.S assumes compressed can be turned off       |                          |                                        |
| #22             | 24-Nov-18            | brouhaha            | I-MISALIGN_LDST-01 assumes misaligned data access will trap    | bug - not fixable in v.1 | will be fixed in V.2                   |
| #31             | 25-Jan-19            | debs-sifive         | I-MISALIGN_JMP-01.S outdated `mbadaddr` in trap handler?       |                          |                                        |
| #63             | 13-Aug-19            | jeremybennett       | Global linker script is not appropriate bug                    |                          |                                        |
| #72             | 26-Oct-19            | vogelpi             | Allow for non-word aligned `mtvec`                             |                          |                                        |
| # <del>11</del> | <del>26-Oct-18</del> | <del>neelgala</del> | illegal.S in rv32mi : S-mode int not always supported (closed) |                          | will be fixed in V.2                   |
| #27             | 21-Dec-18            | jlucnagel           | Macros are checking side-effects                               |                          |                                        |
| #28             | 21-Dec-18            | bluewww             | I-SB-01 test war hazard (address register)                     | fixed?                   | Close?                                 |
| #32             | 25-Jan-19            | debs-sifive         | breakpoint.s undesired behavior when trigger does not exist?   | lixeu:                   | Close:                                 |
| #33             | 28-Jan-19            | debs-sifive         | rv32si/ma_fetch.S has a diff. sign depending on RVC support    |                          |                                        |
| #67             | 25-Sep-19            | rongcuid            | RV32I Immediate Operands error                                 |                          | commit cae8567?                        |
| #97             | 05-Mar-20            | dsw                 | rv64i/Makefrag, variable rv64i_sc_tests contains SRAIW twice   | low priority bug         |                                        |
| #45             | 12-Feb-19            | debs-sifive         | Reorganization of test suites for code maintainability         | low priority bug         | will be fixed in V.2                   |
| #28             | 21_lan_10            | canthochulci        | LIR-01 test - Load the data into YO GDP register /closed       | not a hua2               | closod                                 |

# Next Meeting Agenda (in order of Priority)

- Next steps
  - More tests?
    - Better coverage of existing tests vs. new tests (primarily priv level)
  - Coverage metrics?
  - Transitioning to v.2?
  - Funding?
  - Get more repo maintainers
  - Other?



# Draft Test Coverage Proposal (unpriv)

#### Classes of things we want to test for

- Decode
  - Immediate test all bits in either polarity will affect output
  - Register specifiers test that changing any bit will affect output, ensure all regs are tested
  - Variations test values of opcodes suffixes that have any string after a "." in its opcode
- Register combinations
  - Destructive (dest = either src) and non-destructive
  - Non-updating (i.e., targeting X0), or non-supplying (X0 as an input)
  - All registers (or immediate bit) should be used per instruction \*category\*
- Special and exception cases
  - Explicitly defined (e.g. shifts>=XLEN & RD=X0
  - Implicitly defined corner cases
    - Maximal and minimal inputs, or creating maximal outputs
    - Inputs that special case outputs (mostly FP cases, also. shiftamt>=XLEN)
    - Outputs crossing value boundary (e.g. address cross word/page/superpage/VA boundary, FP crossing exponent boundary)

This works for 32i base ops – what do we need to add for priv modes? Mem model? Sequential Dependencies? Other extensions?

Need a review of existing (non-RISC-V) compliance specs

### proposed coverage & categories

Arith[I], W1/0,crys

Logical[I], W1/0

Shift[I], W1/0/msk,+

Auipc,Lui,

Ld,St, W1/0, bndXing Br, W1/0, bndXing

Jmp , W1/0, bndXing

Ebreak/ Ecall

W1/0= walking 1/0

BndXing=: boundary crossing

# Draft Test Coverage Proposal (more, incl priv)

- Forwarding: result of one op can be used as the source of the very next instruction
  - Need at least a case within and between instruction classes
- Changing non-reg state used by an op, immediately followed by op that uses it, e.g.:
  - changing the rounding mode for an FP op
  - writing into the instruction stream, followed by a fencei affecting the next ifetch
  - changing a page table entry or PMP entry, or SATP affecting the next access
  - changing xEPC or xSTATUS followed by xRET
  - · changing MISA followed by any op enabled or disabled by it
  - changing xTVEC, xDELEG, xIE followed by a trap
  - write once behavior (PMP-lock)
- Ops that change non-reg status, immediately followed by op that tests it, e.g.:
  - FP status after an FP op
  - xSTATUS.FS,XS fields after FP, Vector or other coprocessor op
  - xCAUSE, xEPC, xTVAL, xPP after an interrupt or exception

### RISCV-CONFIG

- Examples & definitions
  - https://github.com/riscv/riscv-config/tree/master/examples
  - https://github.com/riscv/riscv-config/tree/master/riscv\_config/schemas
  - https://github.com/riscv/riscv-compliance/tree/master/riscv-ovpsim/config-yaml/examples
- Validator
  - https://github.com/riscv/riscv-config/blob/master/riscv\_config/checker.py
- Example integration of converter (OVPsim)
  - https://github.com/riscv/riscv-compliance/tree/master/riscv-ovpsim/config-yaml
- WARL, YAML
  - https://riscv-config.readthedocs.io/en/latest/

### RISCV-CONFIG WARL Syntax

WARL: {optional items in curly braces}

- dependency\_fields: [list] use this when legal/illegal values depend on other fields (in list)
- legal: [<warl-string>{,<warl-string>\*}]
- wr\_illegal: [<warl-string>{,<warl-string>\*}] -> update\_mode
   where <warl-string> is either "&" separated list of rangehi:rangelo lists
   {[dependency\_value] ->} field-name1[bit#hi:bit#lo] in [legal-range-list]
   { & field-name2[bit#hi:bit#lo] in [legal-range] }\*

or "&" separated list of bitmasks

```
{[dependency_value] ->} field-name1[bit#hi:bit#lo] bitmask [mask, fixval] { & field-name2[bit#hi:bit#lo] bitmask [mask, fixval] }*
```

(can't mix ranges and bitmasks)

## RISCV-CONFIG WARL Example 1

```
When base of mtvec depends on the mode field.
WARL:
 dependency_fields: [mtvec::mode]
 legal:
  - "[0] -> base[29:0] in [0x20000000, 0x20004000]"
                                                               # can take only 2 fixed values when mode==0.
  - "[1] -> base[29:6] in [0x00000:0xF00000] & base[5:0] in [0x00]" # 256 byte aligned when mode==1
 wr illegal:
  - "[0] -> unchanged"
  - "[1] wr val in [0x2000000:0x4000000] -> 0x2000000"
                                                               # predefined value if write value is in this range
  - "[1] wr val in [0x4000001:0x3FFFFFFF] -> unchanged"
                                                               # predefined value if write value is this range
      When base of mtvec depends on the mode field. Using bitmask instead of range
WARL:
 dependency_fields: [mtvec::mode]
 legal:
  - "[0] -> base[29:0] in
                             [0x20000000, 0x20004000]"
                                                               # can take only 2 fixed values when mode==0.
  - "[1] -> base[29:0] bitmask [0x3FFFFFC0, 0x00000000]"
                                                               # 256 byte aligned when mode==1
 wr illegal:
  - "[0] -> unchanged"
                                                               # no illegal for bitmask defined legal strings.
```

# RISCV-CONFIG WARL Example 2

# no dependencies. Mode field of mtvec can take only 2 legal values using range-descriptor WARL: dependency\_fields: legal: - "mode[1:0] **in** [0x0:0x1] # Range of 0 to 1 (inclusive)" # default to 0 if not a legal value wr illegal: - "0x00" # no dependencies. using single-value-descriptors WARL: dependency fields: legal: - "mode[1:0] **in** [0x0,0x1] # also Range of 0 to 1 (inclusive)" wr\_illegal: - "0x00" - "[1] wr val in [0x2000000:0x4000000] -> 0x2000000 & wr val in [0x4000001:0x3FFFFFFF] -> unchanged